草庐IT

Android AsyncTask 用于长时间运行的操作

全部标签

ruby-on-rails - find_or_initialize_by 不适用于 2 列

我正在尝试使用ActiveRecord在我的数据库中插入数据。当我使用pdays=MyModel.new而不是下面的find_or_initialize_by进行初始化时,脚本运行良好。但它只运行一次。我需要它每天运行以执行更新。当我第二次尝试使用pdays=MyModel.new运行脚本时,没有出现重复键约束。因此,我正在尝试使用以下带有2个参数的find_or_initialize_by,但这给出了一个错误:undefinedmethod`find_or_initialize_by'2列一起构成唯一记录:vertica_traffic.eachdo|vdays|pdays=MyMo

ruby - 在不弄乱输出的情况下打印 Ruby 中并行操作的输出的最简单方法是什么?

假设我fork了一堆线程,并希望将每个线程的进度输出打印到STDERR。我怎样才能确保输出保持行原子性,即不会在同一输出行中混淆来自不同线程的输出?#runthisafewtimesandyou'llseetheproblemthreads=[]10.timesdothreads 最佳答案 puts有一个竞争条件,因为它可能将换行符与行分开写。您可能会在多线程应用程序中使用puts看到这种噪音:thread0thread1thread0thread2thread1thread0thread3thread2thread1相反,使用pr

ruby - 如何在 heroku 上运行 phantomjs?

我正在尝试在herokucedar堆栈上运行phantomjs。我正在为heroku使用phantomjsbuildpackhttps://github.com/stomita/heroku-buildpack-phantomjs.但是我按照说明进行操作,但仍然无法正常工作。当我运行命令herokurunbash并输入phantomjs--version它说phantomjs:commandnotfound我阅读了有关需要设置为“/usr/local/lib:/usr/lib:/lib:/app/vendor/phantomjs/lib”的LD_LIBRARY_PATH的内容,这就是我

ruby - 如何知道代码在什么环境下运行?

在haml的layout文件中,我想确定我们是否在我们的开发和构建环境中。我们正在使用中间人。我想做这样的事情:-ifenvironment=='development'/DevelopmentCode=javascript_include_tag"Dev.js"我尝试访问Ruby的环境变量,并在config.rb文件中定义自定义变量,但没有成功。 最佳答案 你几乎做对了——你需要检查一个符号而不是一个字符串:-ifenvironment==:development/DevelopmentCode=javascript_includ

ruby - 使用ruby递归地运行目录中的文件

我现在正在编写脚本,它必须在目录及其子文件夹中运行每个ruby​​脚本。例如run-all.rb-scripts-folder1-script1.rb-script2.rb-folder2-script3.rb-script4.rb由于服务器是Windows服务器,我通常会使用批处理文件,但开发负责人坚持一切都必须用ruby​​完成,因为有些成员使用Mac,可能不理解Windows批处理文件。由于问题可能已经泄露,我对Ruby的了解非常基础。 最佳答案 取决于你所说的“运行”是什么意思。要在同一个ruby​​进程中执行每个脚本中的代

ruby - 在不保存的情况下运行 ActiveRecord 验证

我有一组ActiveRecord对象。我希望能够为这些对象中的每一个运行所有验证,而无需将它们实际保存到数据库中。我只想知道如果我将它们保存到数据库中它们是否有效。换句话说,我基本上想为我的每个对象填充errors数据结构。有没有办法做到这一点?或者我可能遗漏了一些关于errors集合的生命周期的信息? 最佳答案 您可以执行以下操作来检查模型是否有效:@user=User.newif@user.valid?#dothings如果你想看看错误是什么,你可以这样做:@user=User.newunless@user.valid?@use

ruby - 运行 RSpec 中所有示例的命令行,包括被过滤掉的示例?

有几个例子比较慢,过滤掉如下:RSpec.configuredo|c|c.filter_run_excludingslow:trueenddescribe'getaveragesbuttakesalongtime',slow:truedoit'getsaveragefoo'do....endit'getsaveragebar'do...endend这很好用并且不会运行缓慢的测试。rspec但是从命令行运行所有示例的RSpec命令是什么,包括被过滤掉的慢的? 最佳答案 如果您运行rspec--help,输出包括以下内容:-t,--ta

ruby-on-rails - 用于存储桶中 Ruby 访问文件夹的 aws-sdk

我在AmazonS3上有一个存储桶,里面有文件夹。我正在尝试通过aws-sdkgem以下列方式访问它:s3=AWS::S3.new(:access_key_id=>"KEY",:secret_access_key=>"SECRET")bucket=s3.buckets["my_bucket/my_folder"]bucket.do_stuff....返回以下错误:您尝试访问的存储桶必须使用指定的端点进行寻址。请将所有future请求发送到此端点。知道我做错了什么吗? 最佳答案 可能尝试使用的S3存储桶位于美国东部(默认位置)之外,因

ruby-on-rails - 运行 Rspec 时出现 "No such file to load"错误

MacOS10.4rspec(1.1.11,1.1.4,1.1.3,0.5.15)rspec-rails(1.1.11)rspec_generator(0.5.15)rails2.2.2ruby1.8.6(2007-03-13patchlevel0)[universal-darwin8.0]创建了一个新项目...$railsmyproject将rspec安装到项目中...$script/generaterspec生成资源...$script/generaterspec_scaffoldmyresourcename:stringdescription:text试图运行规范...$rake

ruby-on-rails - 如何在没有 CRUD 操作的情况下路由 Controller ?

我有一个包含许多操作的Controller:classTestsController当我像这样将它添加到我的routes.rb文件中时:resources:tests并执行rakeroutes任务我看到以下额外回合:testsGET/tests(.:format)tests#indexPOST/tests(.:format)tests#createnew_testGET/tests/new(.:format)tests#newedit_testGET/tests/:id/edit(.:format)tests#edittestGET/tests/:id(.:format)tests#s